package com.huike.report.mapper;

import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Map;

/**
 * 首页统计分析的Mapper
 */
public interface ReportMapper {

    /**=========================================基本数据========================================*/
    /**
     * 获取线索数量
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return
     */
    Integer getCluesNum(@Param("startTime") String beginCreateTime,
                        @Param("endTime") String endCreateTime,
                        @Param("username") String username);

    /**
     * 获取商机数量
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return
     */
    Integer getBusinessNum(@Param("startTime") String beginCreateTime,
                           @Param("endTime") String endCreateTime,
                           @Param("username") String username);

    /**
     * 获取合同数量
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return
     */
    Integer getContractNum(@Param("startTime") String beginCreateTime,
                           @Param("endTime") String endCreateTime,
                           @Param("username") String username);

    /**
     * 获取合同金额
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return
     */
    Double getSalesAmount(@Param("startTime") String beginCreateTime,
                          @Param("endTime") String endCreateTime,
                          @Param("username") String username);


    /**=========================================今日简报========================================*/
    /**=========================================今日简报========================================*/

    Integer getTodayCluesNum(String username);
    Integer getTodayBusinessNum(String username);
    Integer getTodayContractNum(String username);
    Double getTodaySalesAmount(String username);

    /**=========================================待办事项========================================*/
    /**=========================================待办事项========================================*/
    Integer getToallocatedCluesNum(@Param("startTime") String startTime,
                                   @Param("endTime") String endTime ,
                                   @Param("username") String username);
    Integer getToallocatedBusinessNum(@Param("startTime") String startTime,
                                      @Param("endTime") String endTime ,
                                      @Param("username") String username);
    Integer getTofollowedCluesNum(@Param("startTime") String startTime,
                                  @Param("endTime") String endTime ,
                                  @Param("username") String username);
    Integer getTofollowedBusinessNum(@Param("startTime") String startTime,
                                     @Param("endTime") String endTime ,
                                     @Param("username") String username);

    //线索统计 - 线索转化率
    Integer getCluesNums(@Param("beginTime") String beginTime, @Param("endTime") String endTime);
    Integer getEffectiveCluesNums(@Param("beginTime") String beginTime, @Param("endTime") String endTime);
    Integer getBusinessNums(@Param("beginTime") String beginTime, @Param("endTime") String endTime);
    Integer getContractNums(@Param("beginTime") String beginTime, @Param("endTime") String endTime);

   /**
   首页 - 商机转化龙虎榜
   */

    int allBusinessNum(@Param("beginCreateTime") String beginCreateTime,
                       @Param("endCreateTime") String endCreateTime);

    List<Map<String,Object>> contractNumByUser(@Param("beginCreateTime") String beginCreateTime,
                                               @Param("endCreateTime") String endCreateTime);


    //首页 - 线索转化龙虎榜
    int allClueNum(@Param("beginCreateTime") String beginCreateTime,
                   @Param("endCreateTime") String endCreateTime);

    List<Map<String, Object>> clueNumByUser(@Param("beginCreateTime") String beginCreateTime
                                            , @Param("endCreateTime") String endCreateTime);

    String getDeptName(String create_by);
}
